//
//       ██████╗ ██╗   ██╗ ██████╗
//       ██╔══██╗██║   ██║██╔════╝
//       ██████╔╝██║   ██║██║  ███╗
//       ██╔══██╗██║   ██║██║   ██║
//       ██████╔╝╚██████╔╝╚██████╔╝
//       ╚═════╝  ╚═════╝  ╚═════╝
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <string>
#include <cmath>
#include <vector>
#include <set>
#include <map>
#include <unordered_map>
#include <unordered_set>
#include <iomanip>
#include <climits>
#define int long long 
#define x first 
#define y second 
using namespace std ;
typedef pair<int,int> PII;
const int N = 1e5 + 10;
int a[N];
PII p[N];
vector<int> G[N];
void solve()
{
      int cnt = 0;
      int n;
      cin >> n;
      string str;
      cin >> str;
      str = " " + str;
      for(int i = 1; i <= n - 1; i++)
      {
          int u,v;
          cin >> u >> v;
          if(str[u] == str[v]) cnt ++ ; 
      }
     cout << cnt << endl;
}
signed main()
{
    ios::sync_with_stdio(false);
    cin.tie(nullptr),cout.tie(nullptr);
    int t  = 1 ;
    //cin >> t;
    while(t -- ) solve();
    return 0;
}
